1 WHAT IS CLAIMED IS : 
2 

3 1: A method of controlling movement in a dynamic system which can be expressed 

4 in terms of both rigid and flexible modes, the method comprising the steps of: 

5 generating a rigid body input for the dynamic system; 

6 processing the rigid body input so as to produce a processed input which 

7 compensates for vibrations in the flexible mode of the system; and 

8 applying the processed input to control the dynamic system. 
9 

10 2. A method according to Claim 1, wherein the generating step comprises (i) 

1 1 creating a model of the rigid mode of the dynamic system based on a modal 

12 analysis, and (ii) determining the rigid body input based on the modal analysis. 
13 

14 3 . A method according to Claim 1 ; wherein the rigid body input corresponds to a 

1 5 fundamental limiting parameter of the system, the fundamental limiting parameter 

16 of the system comprising a first parameter of the system to enter into saturation. 



4 17 



H 18 4. A method according to Claim 3, wherein the processing step processes the rigid 
3 19 body input in accordance with a system vibration limiting constraint and a system 



20 sensitivity constraint. 



21 



* 22 5. A method according to Claim 4, wherein the system vibration limiting and 

23 sensitivity constraints reduce vibration during movement of a component of the 

24 dynamic system by less than 100%. 
25 

26 6. A method according to Claim i; wherein the processing step processes the rigid 

27 body input in accordance with one or more constraints that are a function of a 

28 movement distance of a component of the dynamic system. 
29 
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A method according to Claim 1, wherein the processing step processes the rigid 
body input in accordance with a system vibration limiting constraint only. 



A method according to Claim 1, wherein the processing step shapes the rigid body 
input using a predetermined shaping function. 

A method according to Claim 8 5 . wherein the rigid body input includes both 
transient portions and a steady state portion; and 

wherein only the transient portions of the rigid body input are shaped in 

accordance with the predetermined shaping function. 

A method according to Claim 1 , wherein the processing step processes the rigid 
body input by filtering the input using filters having zeros which are substantially 
near poles of the system. 

A method according to Claim 1, wherein the processing step processes the rigid 
body input in accordance with at least one of constraints relating to system 
thermal limits, system current limits, and system duty cycle. 

A method according to Claim 1, wherein the processing step processes the rigid 
body input by determining a movement distance of a component of the dynamic 
system and modifying the rigid body input based on the movement distance. 

A method according to Claim 1, wherein the rigid body input comprises a 
Posicast input. 

A method according to Claim 1, wherein the rigid body input comprises a 
symmetric input. 



A method according to Claim 1, wherein the processing step processes the rigid 
body input in accordance with a symmetric constraint that varies as a function of 
at least one of time and position of a component of the dynamic system. 

A method according to Claim l, wherein the rigid body input comprises a voltage 
which has been controlled by controlling current. 

A method according to any one of Claims 1 to 16, wherein the processing step 
comprises: 

identifying system parameters in real-time; and 

modifying the rigid body input in real-time in accordance with the system 
parameters identified in the identifying step. 

A method according to Claim 2, wherein the determining step determines the 
rigid body input in accordance with an insensitivity constraint. 

A method according to Claim 2, wherein the model of the system comprises a 

plurality of equations for the system; and 

wherein an insensitivity constraint for a particular system parameter is 
added to the system by taking a derivative of a system equation with 
respect to the insensitivity constraint and setting the derivative equal to 
zero. 

A method according to Claim 2, wherein the model of the system comprises a 

plurality of equations for the system; and 

wherein an insensitivity constraint for a particular system parameter is 
added to the system by setting a series of constraints for different values of 
the system parameter so as to limit a variation in the system parameter. 



A method according to Claim 2, wherein the rigid body input is determined in 

accordance with a feedback signal; and 

wherein the method further comprises adding a quasi-static correction 
factor to the feedback signal, the quasi-static correction factor correcting 
for a deflection in the component during movement. 

A method according to Claim 2, further comprising determining a center of mass 
of a component of the dynamic system; 

wherein the rigid body input is determined in accordance with a feedback 

signal based on the center of mass of the component. 

A method of determining plural switch times for a voltage input to a dynamic 
system having plural modes, the method comprising the steps of: 

generating a model of the dynamic system based on a modal analysis of 

each of the plural modes; 

determining a response of the dynamic system in terms of the modal 
analysis in the model; 

determining an expression for a contribution of each of the plural modes to 
a final location of the system based on a corresponding response, the 
contribution of each mode of the system being based on switch times for 
the voltage input; 

estimating values relating to the plural switch times; and 
calculating approximations of the values relating to the plural switch times 
based on the estimated values using the expression for the contribution of 
each of the plural modes and the modal analysis in the model of the 
dynamic system. 

A method according to Claim 23; further comprising the step of re-calculating 
approximations of the values based on a previous approximation the values. 



A method according to Claim 24, wherein the re-calculating step is repeated a 
plurality of times, each time using a re-calculated approximation of the values as 
the previous approximation of the values. 

A method according to Claim 23, further comprising the step of generating a table 
comprising plural switch times; 

wherein the estimating step comprises estimating the values using the 

table. 

A method according to Claim 23, further comprising the step of generating at 
least one curve corresponding to the plural switch times; 

wherein the estimating step comprises estimating the values using the at 

least one curve. 

A method according to Claim 23, wherein the dynamic system comprise a data 
storage device; and 

wherein the voltage inputs comprise voltage inputs to the data storage 

device. 

A method according to Claim 23, further comprising the step of performing input 
shaping on the voltage input after switch times therefor have been calculated. 

A method according to Claim 23, wherein the estimating step is performed using 
a parameter estimator. 

A method of reducing unwanted vibrations in a dynamic system, the method 
comprising the steps of: 

determining whether greater than a predetermined level of vibrations will 

be excited by a system input; and 
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modifying the input to the dynamic system in a case that greater than the 
predetermined level of vibrations will be excited, where the input to the 
dynamic system is modified so as to reduce the level of vibrations in the 
system to less than the predetermined level of vibrations 

32. A method according to Claim 3 1 , wherein the modifying step comprises using at 
least one of an input shaper, an inverse shaper, and a filter in order to modify the 
input to the dynamic system. 

33. An apparatus which controls a dynamic system that can be expressed in terms of 
both rigid and flexible modes, the apparatus comprising: 

a memory which stores computer-executable process steps; and 
a processor which executes the process steps stored in the memory so as 
(i) to generate a rigid body input for the dynamic system, (ii) to process 
the rigid body input so as to produce a processed input which compensates 
for vibrations in the flexible mode of the system, and (iii) to apply the 
processed input to control the dynamic system. 

34. An apparatus according to Claim 33, wherein the processor generates the rigid 
body input by (i) creating a model of the rigid mode of the dynamic system based 
on a modal analysis of the system, and (ii) determining an input to the dynamic 
system based on the modal analysis, 

35. An apparatus according to Claim 32, wherein the rigid body input comprises a 
fundamental limiting parameter of the system, the fundamental limiting parameter 
of the system corresponding to a first parameter in the system to enter into . 
saturation. 



-83- 



An apparatus according to Claim 35, wherein the processor processes the rigid 
body input in accordance with a system vibration limiting constraint and a system 
sensitivity constraint. 

An apparatus according to Claim 36, wherein the system vibration limiting and 
sensitivity constraints reduce vibration during movement of the component by 
less than 100%. 

An apparatus according to Claim 33 5 wherein the processor processes the rigid 
body input in accordance with one or more constraints that are a function of a 
movement distance of a component of the dynamic system. 

An apparatus according to Claim 33, 'wherein the processor processes the rigid 
body input in accordance with a system vibration limiting constraint only. 

An apparatus according to Claim 33, wherein the processor shapes the rigid body 
input using a predetermined shaping function. 

An apparatus according to Claim 40, Wherein the rigid body input includes both 

transient portions and a steady state portion; and 

wherein the processor shapes only the transient portions of the rigid body 
input in accordance with the predetermined shaping function. 

An apparatus according to Claim 33, wherein the processor processes the rigid 
body input by filtering the input using filters having zeros which are substantially 
near poles of the system. 

An apparatus according to Claim 33, wherein the processor processes the rigid 
body input in accordance with at least one of constraints relating to system 
thermal limits, system current limits, and system duty cycle. 



An apparatus according to Claim 33, wherein the processor processes the rigid 
body input by determining a movement distance of a component of the dynamic 
system and modifying the input based on the movement distance. 

An apparatus according to Claim 33 , wherein the rigid body input comprises a 
Posicast input. 

An apparatus according to Claim 3 3, .wherein the rigid body input comprises a 
symmetric input. 

An apparatus according to Claim 33; wherein the processor processes the rigid 
body input in accordance with a symmetric constraint that varies as a function of 
at least one of time and position of a component of the dynamic system. 

An apparatus according to Claim 33; wherein the processor processes the rigid 
body input based on a voltage which has been controlled by controlling current. 

An apparatus according to any one of Claims 33 to 48, wherein the processor 
processes the rigid body input by (i) identifying system parameters in real-time, 
and (ii) modifying the input in real-time in accordance with the system parameters 
identified by the processor. 

An apparatus according to Claim 33, wherein the processor generates the rigid 
body input in accordance with an insensitivity constraint. 

An apparatus according to Claim 50, wherein the model of the system comprises a 

plurality of equations for the system; and 

wherein an insensitivity constraint for a particular system parameter is 
added to the system by taking a derivative of a system equation with 



1 respect to the insensitivity constraint and setting the derivative equal to 

2 zero. 
3 

4 52. An apparatus according to Claim 50, wherein the model of the system comprises a 

5 plurality of equations for the system; and 

6 wherein an insensitivity constraint for a particular system parameter is 

7 added to the system by setting a series of constraints for different values of 

8 the system parameter so as to limit a variation in the system parameter. 
9 

10 53. An apparatus according to Claim 33, wherein the processor generates the rigid 

1 1 body input in accordance with a feedback signal; and 

1 2 wherein the processor adds a quasi-static correction factor to the feedback 

1 3 signal, the quasi-static correction factor correcting for a deflection in the 

14 component during movement. 
15 

16 54. An apparatus according to Claim 33, wherein the processor determines a center of 

17 mass of a component of the dynamic system; and 

1 8 wherein the processor generates the rigid body input in accordance with a 

1 9 feedback signal based on the center of mass of the component. 
20 

21 55. An apparatus which determines plural switch times for a voltage input into a 

22 dynamic system having plural modes, the apparatus comprising: 

23 a memory which stores computer-executable process steps; and 

24 a processor which executes the process steps stored in the memory so as 

25 (i) to generate a model of the dynamic system in terms of a modal analysis 

26 each of the plural modes, (ii) to determine a response of the dynamic 

27 - system in terms of the modal analysis in the model, (iii) to determine an 

28 expression for a contribution of each of the plural modes to a final location 

29 of the system based on a corresponding response, the contribution of each 

30 mode of the system being based on switch times for the voltage input, (iv) 
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to estimate values corresponding to the plural switch times, and (v) to 
calculate approximations of the values corresponding to the plural switch 
times based on the estimated values using the expression for the 
contribution of each of the plural modes and the modal analysis in the 
model of the dynamic system. 

An apparatus according to Claim 55, wherein the processor re-calculates 
approximations of the values based on a previous approximation of the values. 

An apparatus according to Claim 56, wherein the processor re-calculates 
approximations of the values a plurality of times, each time using a re-calculated 
approximation of the values as the previous approximation of the values. 

An apparatus according to Claim 55, wherein the processor generates a table 
comprising plural switch-times; and 

wherein the processor estimates the values using the table. 

An apparatus according to Claim 55, wherein the processor generates at least one 
curve corresponding to the plural switch times; and 

wherein the processor estimates the values using the at least one curve. 

An apparatus according to Claim 55, wherein the dynamic system comprises a 
y data storage device; and 

1 wherein the voltage inputs comprise voltage inputs to the data storag e 

device. 



An apparatus according to Claim 55, further comprising the step of performing 
input shaping on the voltage input after switch times therefor have been 
calculated. 



1 62. An apparatus which reduces unwanted vibrations in a dynamic system, the 

2 apparatus comprising: 

3 a memory which stores computer-executable process steps; and 

4 a processor which executes the process steps stored in the memory so as 

5 (i) to determine whether greater than a predetermined level of vibrations 

6 will be excited by an input to the system, and (ii) to modify the input to 

7 the dynamic system in a case that greater than the predetermined level of 

8 vibrations will be excited, where the processor modifies the input to the 

9 dynamic system so as to reduce the level of vibrations in the system to less 
1 0 than the predetermined level of vibrations. 

11 

12 63. An apparatus according to Claim 62, wherein the processor modifies the input to 

Q 13 the dynamic system using at least one of an input shaper, an inverse shaper, and a 

1;{ 14 filter. 
M 15 

rij 16 64. A method of controlling a dynamic system in accordance with an input that is a 

^ 1 7 function of time so as to reduce unwanted vibrations in the system, the method 

a 18 comprising the steps of: 

W\ 19 generating a model of the dynamic system, the model defining system 

y 20 position in terms of both time and a system input, and the model 

Q 2 1 constraining the system in accordance with one or more constraints 

22 relating to the unwanted vibrations; 

23 determining an input to the dynamic system which reduces the unwanted 

24 vibrations based on the model generated in the generating step; and 

25 controlling the dynamic system in accordance with the input determined in 

26 the determining step. 
27 

28 65. A method according to Claim 64, wherein the model of the system comprises a 

29 partial fraction expansion of third order equations that define the system. 
30 
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A method according to Claim 65, wherein the partial fraction expansion equations 
comprise: 

Finalpos = ^ Vi A At 

N Ah 

0 = y Yi — — ( e ' a(T "*- TiJr6t) -e a(Ttnd ' T,) ) 

N An 

0 =Y Yi — ( e - b (T««-T>^)„ e -l>(T„ d -T i ) )j 

where Finalpos is the final position of a component of the dynamic system, T en d 
corresponds to a time at which Finalpos is reached, A, a and b are based on the 
system parameters, Vi are voltage inputs to the system, Tj are the times at which 
Vi are input, and ) t is a time interval at which Vi are input. 

A method according to Claim 64, wherein the input determined in the determining 
step comprises the fundamental limiting parameter of the system, the fundamental 
limiting parameter corresponding to a first parameter in the system to enter into 
saturation. 

A method of using a current command to control a system having voltage as a 
physical limiting parameter, where the system includes a current controller 
connected to a power supply, the method comprising the steps of: 
inputting a current command to the system; 

shaping the current command using a unity magnitude shaper so that the 
current controller in the system goes into saturation; and 
supplying voltage to the system from the power supply via the current 
controller in saturation. 



• # 

A method of controlling a dynamic system having one or more feedforward 
inputs, where one of the feedforward inputs corresponds to a fundamental limiting 
parameter of the system, the method comprising the steps of: 

altering a form of a feedforward input that corresponds to the fundamental 
limiting parameter of the system so as to reduce unwanted dynamics of the 
system. 

A method according to Claim 69, further comprising the step of determining the 
fundamental limiting parameter of the system by identifying a first parameter of 
the system to enter into saturation. 

A method according to Claim 69, wherein the altering step comprises shaping the 
feedforward input. 

A method according to Claim 71, wherein the shaping is performed using Input 
Shaping™. 

A method according to Claim 71, wherein the shaping is performed using one or 
more filters. 

A method according to Claim 71, further comprising the steps of: 
identifying any nonlinear elements in the system; 
wherein the shaping is performed after any nonlinear elements identified 
in the identifying step. 

A method according to Claim 69, wherein the altering step comprises pre- 
saturating the feedforward input and then shaping the feedforward input. 

A method according to Claim 69, wherein the dynamic system comprises a data 
storage device system; and 



1 wherein the fundamental limiting parameter comprises voltage. 
2 

3 77. A data storage device system having one or more feedforward inputs, where one 

4 of the feedforward inputs corresponds to a fundamental limiting parameter of the 

5 system, the system comprising: 

6 a memory which stores computer-executable process steps; and 

7 a processor which executes the process steps stored in the memory so as to 

8 alter a form of a feedforward input that corresponds to the fundamental 

9 limiting parameter of the system so as to reduce unwanted dynamics of the 
10 system. 

11 

12 78. A system according to Claim 77 5 wherein the processor executes process steps so 

P% 13 as to determine the fundamental limiting parameter of the system by identifying a 

^ 14 first parameter of the system to enter into saturation. 
M 15 

16 79. A system according to Claim 77, wherein the feedforward input is altered by 

%\* 

17 shaping the feedforward input. 

r is • 

19 80. A system according to Claim 79, wherein the shaping is performed using Input 

0 20 Shaping™. 

1 21 ■ 

^ 22 81. A system according to Claim 79, wherein the shaping is performed using one or 

23 more filters. 
24 

25 82. A system according to Claim 79, wherein the processor executes process steps so 

26 as to identify any nonlinear elements in the system; 

27 wherein the shaping is performed after any nonlinear elements identified 

28 by the processor. 
29 
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1 83. A system according to Claim 77, wherein the processor alters the feedforward 

2 input by pre-saturating the feedforward input and then shaping the feedforward 

3 input. 
4 

5 84. A method of shaping an input to a dynamic system so as to reduce unwanted 

6 dynamics in the system, the input to the dynamic system comprising digital data 

7 sampled at a predetermined frequency, the method comprising the steps of: 

8 identifying system vibrations that occur at the Nyquist frequency for the 

9 system, the system vibrations corresponding to a sine wave having two 

1 0 sample points per period; and 

1 1 applying a three-pulse shaper to the input, wherein first and second pulses 

12 of the three-pulse shaper are applied at the two sample points in a first 

13 period of the input, and a third pulse of the three-pulse shaper is applied at 

14 a first sample point in a second period of the input. 
15 

16 85. A method of generating an input to a. computer-controlled dynamic system so as 

17 to suppress vibrations therein, the dynamic system having a dedicated path solely 

18 for a feedforward input from a controller to controlled hardware, the method 

19 comprising the steps of: 

20 determining a frequency of vibrations to be suppressed; 

21 wherein, in a case that the frequency of the vibrations to be suppressed is 

22 at or below a servo rate for the dynamic system, the method comprises the 

23 steps of: 

24 executing servo calculations for the system; 

25 determining a servo output based on the servo calculations; and 

26 outputting the servo output as the input to the dynamic system; and 

27 wherein, in a case that the frequency is above the servo rate for the 

28 dynamic system, the method comprises the steps of: 

29 determining ^ trajectory value; 

30 shaping the trajectory; and 
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outputting the shaped trajectory as the input to the dynamic 
system. 



A method of generating an input to a computer-controlled dynamic system so as 
to suppress vibrations therein, the dynamic system having a path by which a 
feedforward input and other signals are output from a controller to controlled 
hardware, the method comprising the steps of: 

executing servo calculations for the system; 

determining a servo output based on the servo calculations; 

storing the servo output in a memory; 

determining a trajectory value for the feedforward input; 

shaping the trajectory value; and 

adding the servo output stored in the memory to the shaped trajectory 
value so as to generate "the feedforward input. 

A method of controlling a dynamic system using an input command, comprising 
the steps of: 

shaping the input command to saturation; 

inputting the saturated command until a first predetermined condition is 
detected; 

shaping a transition of the input command during deceleration from 
saturation until a second predetermined condition occurs; and 
following a preset trajectory until the dynamic system comes to within a 
predetermined proximity of its final state. 

A method according to Claim 87, wherein the preset trajectory comprises a curve 
in a PV table. 

A method of generating commands for a dynamic system in a first parameter 
which maintain a limit in a second parameter, where the second parameter 



1 comprises a fundamental limiting parameter of the dynamic system, the method 

2 comprising the steps of: 

3 determining a response of the second parameter in the dynamic system to 

4 a unit command in the first parameter; and 

5 generating the command in the second parameter based on the response 

6 determined in the determining step. 
7 

8 90. A method according to Claim 89, wherein the first parameter is current and the 

9 second parameter is voltage; and 

1 0 wherein the dynamic system comprises a disk drive. 

11 

12 91. A method according to Claim 89, wherein the response is determine'd by 
q 13 iteratively solving a set of equations for the first parameter knowing at least the 

14 second parameter. 

SJ 15 

^ 1 6 92. A method according to Claim 9 1 , wherein the set of equations comprises: 



. N 



y, 1 8 where A comprises amplitudes of the command in the first parameter at each time 

1 9 interval i, and N comprises a last time interval; 



i-l 



V/ Cvscale ^ 1 Ai > 

j-i 



20 

21 where v comprises a system velocity and C VS caie is a constant; 
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P final = Vi, 

1 

2 where Pfi na i comprises a final state of the system; and 

3 



j 

4 

5 where R comprises a pulse response of the system to the second parameter and 

6 Viim comprises a limit in the second parameter. 
7 

8 93 . A method according to Claim 92, wherein A comprises current, V comprises 

9 voltage, and R comprises a voltage response of the system. 
10 

11 94. A method according to Claim 92, wherein the values of R(i) are determined by 

12 taking a peak value of the system response and sampling values of the system 

13 response at subsequent time increments. 
14 

1 5 95 . A method generating commands for a dynamic system in a first parameter (A) 

16 which maintain a limit in a second parameter (V), where the second parameter (V) 

17 comprises a fundamental limiting parameter of the dynamic system, the method 

1 8 comprising the steps of: 

19 determining a values for a command in the first parameter (A) at time 

20 intervals (i) based on the following relationship: 
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Foax-Z ACi + l'j) RQ) 



R(l) 



where R comprises a pulse response of the system in the second parameter; and 
formulating a command over time in the first parameter (A) based on the 
A(i) values determined in the determining step. 

A method according to Claim 95, wherein A comprises current and V comprises 
voltage. 

A method of controlling a dynamic system having vibrations resulting from 

movement, the method comprising the steps of: 

identifying transitions of an input command to the dynamic system; and 
shaping transitions of the input command so as to result in a system 
response to the input command with reduced vibrations. 

A method of controlling a system to reduce unwanted dynamics using commands 
in both first and second parameters, where the second parameter comprises a 
fundamental limiting parameter of the system, the method comprising: 

commanding the system in the first parameter during a first mode of 

system operation; and 

commanding the system in the second parameter during a second mode of 
system operation. 

A method according to Claim 98, wherein the system comprises a disk drive; 

wherein the first mode of operation comprises tracking performed by the 
disk drive; and 

wherein the second mode of operation comprises seeking performed by 
the disk drive. 



1 

2 1 00. A method according to Claim 92, 94, and 95, wherein Vi™ is varied in accordance 

3 with i. 
4 

5 101 . A method according to Claims 89 to 95, wherein constraints are added for 

6 parameter slew rate limits; and 

7 wherein the generating step generates the command in accordance with the 

8 added constraints. 
9 

10 1 02. A method of rescaling a vibration-limiting input to a dynamic system, the method 

1 1 comprising the step of: 

12 linearly scaling amplitudes of the vibration-limiting input to produce a 

13 scaled vibration-limiting input. 



14 
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